# Conjunto de instrucciones de rango medio mejorado

Esto se aplica a las familias de microcontroladores PIC  $^{\circledR}$  PIC16F1xxx y PIC16LF1xxx .

| Operaciones orientadas a bytes | Op | eraciones | orientadas | a by | /tes |
|--------------------------------|----|-----------|------------|------|------|
|--------------------------------|----|-----------|------------|------|------|

| Mnemónicos<br>Operandos | s,      | Descripción                                  | Ciclos | Código de<br>operación de 14 bits<br>MSbLSb | Estado<br>Afectado | notas |
|-------------------------|---------|----------------------------------------------|--------|---------------------------------------------|--------------------|-------|
| ADDWF                   | f,<br>d | Añadir W y f                                 | 1      | 00 0111 ffff ffff                           | C, CC, Z           | 2     |
| AÑADIRWFC               | f,<br>d | Suma con<br>Carry W y f                      | 1      | 11 1101 ffff ffff                           | C, CC, Z           | 2     |
| ANDWF                   | f,<br>d | Y W con f                                    | 1      | 00 0101 ffff ffff                           | Z                  | 2     |
| ASRF                    | f,<br>d | Desplazamiento<br>aritmético a la<br>derecha | 1      | 11 0111 ffff ffff                           | C, Z               | 2     |
| LSLF                    | f,<br>d | Desplazamiento<br>lógico a la<br>izquierda   | 1      | 11 0101 ffff ffff                           | C, Z               | 2     |
| LSRF                    | f,<br>d | Desplazamiento<br>lógico a la<br>derecha     | 1      | 11 0110 ffff ffff                           | C, Z               | 2     |
| CLRF                    | F       | Borrar f                                     | 1      | 00 0001 1fffffff                            | Z                  | 2     |
| CLRW                    |         | Borrar W                                     | 1      | 00 0001 0000 00xx                           | Z                  |       |
| COMF                    | f,<br>d | Complemento f                                | 1      | 00 1001 ffff ffff                           | Z                  | 2     |
| DECF                    | f,<br>d | Decremento f                                 | 1      | 00 0011 ffff ffff                           | Z                  | 2     |
| FIN                     | f,<br>d | Incremento f                                 | 1      | 00 1010 ffff ffff                           | Z                  | 2     |

| IORWF  | f,<br>d | Inclusivo OR W<br>con f             | 1 | 00 0100 dfff ffff Z 2      |
|--------|---------|-------------------------------------|---|----------------------------|
| MOVF   | f,<br>d | Move f                              | 1 | 00 1000 dfff ffff Z 2      |
| MOVWF  | f       | Move W to f                         | 1 | 00 0000 1fff ffff None 2   |
| RLF    | f,d     | Rotate left f<br>through Carry      | 1 | 00 1101 dfff ffff C 2      |
| RRF    | f,d     | Rotate right f<br>through Carry     | 1 | 00 1100 dfff ffff C 2      |
| SUBWF  | f,d     | Subtract with<br>Borrow W from<br>f | 1 | 11 1011 dfff ffff C,DC,Z 2 |
| SUBWFB | f,d     | Subtract W<br>from f                | 1 | 00 0010 dfff ffff C,DC,Z 2 |
| SWAPF  | f,d     | Swap nibbles in f                   | 1 | 00 1110 dfff ffff None     |
| XORWF  | f,d     | Exclusive OR W with f               | 1 | 00 0110 dfff ffff Z 2      |
|        |         |                                     |   |                            |

#### **Byte Oriented Skip Instructions**

| Mnemonic,<br>Operands |     | Description               | Cycles | 14-bit Opcode<br>MSbLSb | Status<br>Affected | Notes |
|-----------------------|-----|---------------------------|--------|-------------------------|--------------------|-------|
| DECFSZ                | f,d | Decrement f,<br>Skip if 0 | 1(2)   | 00 1011 dfff ffff       | None               | 1,2   |
| INCFSZ                | f,d | Increment f,<br>Skip if 0 | 1(2)   | 00 1111 dfff ffff       | None               | 1,2   |

#### **Bit Oriented File Register Operations**

| Mnemonic,<br>Operands |     | Description | Cycles | 14-bit Opcode<br>MSbLSb | Status<br>Affected | Notes |
|-----------------------|-----|-------------|--------|-------------------------|--------------------|-------|
| BCF                   | f,b | Bit Clear f | 1      | 01 00bb bff ffff        | None               | 2     |
| BSF                   | f,b | Bit Set f   | 1      | 01 01bb bfff ffff       | None               | 2     |

### **Bit Oriented Skip Operations**

| Mnemonic,<br>Operands |     | Description                  | Cycles | 14-bit Opcode<br>MSbLSb | Status<br>Affected | Notes |
|-----------------------|-----|------------------------------|--------|-------------------------|--------------------|-------|
| BTFSC                 | f,b | Bit Test f, Skip if<br>Clear | 1(2)   | 01 10bb bfff ffff       | None               | 1,2   |
| BTFSS                 | f,b | Bit Test f, Skip if<br>Set   | 1(2)   | 01 11bb bfff ffff       | None               | 1,2   |

## **Literal Operations**

|   | Description                    | Cyrolog                                                                                                                                                        | 44146                                                                                                                                                                    |                                                               |
|---|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
|   | _ 3 <b>00p011</b>              | Cycles                                                                                                                                                         | 14-bit Opcode<br>MSbLSb                                                                                                                                                  | Status Notes<br>Affected                                      |
| k | Add literal and<br>W           | 1                                                                                                                                                              | 11 1110 kkkk kkkk                                                                                                                                                        | C,DC,Z                                                        |
| k | AND literal with<br>W          | 1                                                                                                                                                              | 11 1001 kkkk kkkk                                                                                                                                                        | Z                                                             |
| k | Inclusive OR<br>literal with W | 1                                                                                                                                                              | 11 1000 kkkk kkkk                                                                                                                                                        | Z                                                             |
| k | Move literal to<br>BSR         | 1                                                                                                                                                              | 00 0000 001k kkkk                                                                                                                                                        | None                                                          |
| k | Move literal to PCLATH         | 1                                                                                                                                                              | 11 0001 1kkk kkkk                                                                                                                                                        | None                                                          |
| k | Move literal to<br>W           | 1                                                                                                                                                              | 11 0000 kkkk kkkk                                                                                                                                                        | None                                                          |
| k | Subtract W<br>from literal     | 1                                                                                                                                                              | 11 1100 kkkk kkkk                                                                                                                                                        | C,DC,Z                                                        |
| k | Exclusive OR literal with W    | 1                                                                                                                                                              | 11 1010 kkkk kkkk                                                                                                                                                        | Z                                                             |
|   | k<br>k<br>k<br>k               | k AND literal with W k Inclusive OR literal with W k Move literal to BSR k Move literal to PCLATH k Move literal to W k Subtract W from literal k Exclusive OR | k AND literal with W k Inclusive OR 1 literal with W k Move literal to 1 BSR k Move literal to 1 PCLATH k Move literal to W k Subtract W 1 from literal k Exclusive OR 1 | k Add literal and W 1 11 1110 kkkk kkkk W 1 11 1110 kkkk kkkk |

### **Control Operations**

| Mnemonic,<br>Operands |   | Description                   | Cycles | 14-bit Opcode<br>MSbLSb | Status Notes<br>Affected |
|-----------------------|---|-------------------------------|--------|-------------------------|--------------------------|
| BRA                   | k | Relative Branch               | 2      | 11 001k kkkk kkkk       | None                     |
| BRW                   |   | Relative Branch with W        | 2      | 00 0000 0000 1011       | None                     |
| CALL                  | k | Call Subroutine               | 2      | 10 0kkk kkkk kkkk       | None                     |
| CALLW                 |   | Call Subroutine with W        | 2      | 00 0000 0000 1010       | None                     |
| GOTO                  | k | Goto address                  | 2      | 10 1kkk kkkk kkkk       | None                     |
| RETFIE                | k | Return from interrupt         | 2      | 00 0000 0000 1001       | None                     |
| RETLW                 | k | Return, place<br>literal in W | 2      | 11 0100 kkkk kkkk       | None                     |
| RETURN                | k | Return from subroutine        | 2      | 00 0000 0000 1000       | None                     |
|                       |   |                               |        |                         |                          |

### **Inherent Operations**

| Mnemonic,<br>Operands | Description                 | Cycles | 14-bit Opcode<br>MSbLSb | Status Notes<br>Affected |
|-----------------------|-----------------------------|--------|-------------------------|--------------------------|
| CLRWDT                | Clear<br>Watchdog<br>Timer  | 1      | 00 0000 0110 0100       | TO,PD                    |
| NOP                   | No Operation                | 1      | 00 0000 0000 0000       | None                     |
| OPTION                | Load OPTION register with W | 1      | 00 0000 0110 0010       | None                     |
| RESET                 | Software device<br>Reset    | 1      | 00 0000 0000 0001       | None                     |
| SLEEP                 | Go into standby mode        | 1      | 00 0000 0110 0011       | TO, PD                   |
| TRIS f                | Load TRIS<br>register       | 1      | 00 0000 0110 Offf       | None                     |

#### **C-Compiler Optimized**

| Mnemonic,<br>Operands | Description                | Cycles | 14-bit Opcode<br>MSbLSb | Status<br>Affected | Notes |
|-----------------------|----------------------------|--------|-------------------------|--------------------|-------|
| ADDFSR                | Add Literal to<br>FSRn     | 1      | 11 0001 0nkk kkkk       | None               |       |
| MOVIW                 | Move Indirect<br>FSRn to W | 1      | 00 0000 0001 0nnn       | Z                  | 2     |
| MOVWI                 | Move W to<br>Indirect FSRn | 1      | 00 0000 0001 1nnnn      | Z                  | 2     |

#### **Notes**

- 1. If the Program Counter (PC) is modified, or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.
- 2. If this instruction addresses an INDF register *and* the MSb of the corresponding FSR is set, the instruction requires one additional instruction cycle.